<template>
    <a-layout class="layout" :class="[device]">
        <!-- Junvary： 控制不显示侧边栏，在首页的时候 -->
        <template v-if="!showSidebar"></template>
        <template v-else>
            <template v-if="layoutMode === 'sidemenu'">
                <a-drawer v-if="device === 'mobile'" :wrapClassName="'drawer-sider ' + navTheme" placement="left"
                    @close="() => this.collapsed = false" :closable="false" :visible="collapsed" width="200px">
                    <side-menu mode="inline" v-if="device === 'mobile'" :menus="menus" @menuSelect="menuSelect"
                        @updateMenuTitle="handleUpdateMenuTitle" :theme="navTheme" :collapsed="false"
                        :collapsible="true"></side-menu>
                </a-drawer>

                <side-menu v-show="device === 'desktop'" mode="inline" :menus="menus" @menuSelect="myMenuSelect"
                    @updateMenuTitle="handleUpdateMenuTitle" :theme="navTheme" :collapsed="collapsed"
                    :collapsible="true"></side-menu>
            </template>
        </template>
        <!-- 下次优化这些代码 -->
        <template v-else>
            <a-drawer v-if="device === 'mobile'" :wrapClassName="'drawer-sider ' + navTheme" placement="left"
                @close="() => this.collapsed = false" :closable="false" :visible="collapsed" width="200px">
                <side-menu mode="inline" :menus="menus" @menuSelect="menuSelect" @updateMenuTitle="handleUpdateMenuTitle"
                    :theme="navTheme" :collapsed="false" :collapsible="true"></side-menu>
            </a-drawer>
        </template>

        <a-layout :class="[layoutMode, `content-width-${contentWidth}`]"
            :style="{ paddingLeft: fixSiderbar && isDesktop() ? `${sidebarOpened ? 200 : 80}px` : '0' }">
            <!-- layout header -->
            <global-header :mode="layoutMode" :menus="menus" :theme="navTheme" :collapsed="collapsed" :device="device"
                @toggle="toggle" @updateMenuTitle="handleUpdateMenuTitle" />

            <!-- layout content -->
            <a-layout-content :style="{ height: '100%', paddingTop: fixedHeader ? '59px' : '0' }">
                <slot></slot>
            </a-layout-content>

            <!-- layout footer -->
            <a-layout-footer style="padding: 0px">
                <global-footer />
            </a-layout-footer>
        </a-layout>

        <!-- update-start---- author:os_chengtgen -- date:20190830 --  for:issues/463 -编译主题颜色已生效，但还一直转圈，显示主题 正在编译 ---- -->
        <!--<setting-drawer></setting-drawer>-->
        <!-- update-end---- author:os_chengtgen -- date:20190830 --  for:issues/463 -编译主题颜色已生效，但还一直转圈，显示主题 正在编译 ---- -->
    </a-layout>
</template>

<script>
import SideMenu from '@/components/menu/SideMenu'
import GlobalHeader from '@/components/page/GlobalHeader'
import GlobalFooter from '@/components/page/GlobalFooter'
import { triggerWindowResizeEvent } from '@/utils/util'
import { mapActions, mapState } from 'vuex'
import { mixin, mixinDevice } from '@/utils/mixin.js'
// update-start---- author:os_chengtgen -- date:20190830 --  for:issues/463 -编译主题颜色已生效，但还一直转圈，显示主题 正在编译 ------
// import SettingDrawer from '@/components/setting/SettingDrawer'
// 注释这个因为在个人设置模块已经加载了SettingDrawer页面
// update-end ---- author:os_chengtgen -- date:20190830 --  for:issues/463 -编译主题颜色已生效，但还一直转圈，显示主题 正在编译 ------

export default {
    name: 'GlobalLayout',
    components: {
        SideMenu,
        GlobalHeader,
        GlobalFooter,
        // update-start---- author:os_chengtgen -- date:20190830 --  for:issues/463 -编译主题颜色已生效，但还一直转圈，显示主题 正在编译 ------
        // // SettingDrawer
        // 注释这个因为在个人设置模块已经加载了SettingDrawer页面
        // update-end ---- author:os_chengtgen -- date:20190830 --  for:issues/463 -编译主题颜色已生效，但还一直转圈，显示主题 正在编译 ------

    },
    mixins: [mixin, mixinDevice],
    data() {
        return {
            collapsed: false,
            activeMenu: {},
            menus: [],
            // Junvary：为了以后不显示侧边栏的需求，指定忽略列表，存放 fullPath
            noSidebarMenuList: ['/dashboard/analysis'],
        }
    },
    computed: {
        ...mapState({
            // 主路由
            mainRouters: state => state.permission.addRouters,
            // 后台菜单
            permissionMenuList: state => state.user.permissionList,
            // Junvary：获取menuIndex，覆写menus的获取方式
            menuIndex: (state) => state.user.menuIndex,
            // Junvary：控制是否显示侧边栏，首页的时候不显示
            showSidebar: (state) => state.app.showSidebar,
        })
    },
    watch: {
        sidebarOpened(val) {
            this.collapsed = !val
        },
        // Junvary：监视menuIndex，来动态改变menus
        menuIndex() {
            this.fillMenus()
        },
    },
    created() {
        //--update-begin----author:scott---date:20190320------for:根据后台菜单配置，判断是否路由菜单字段，动态选择是否生成路由（为了支持参数URL菜单）------
        //this.menus = this.mainRouters.find((item) => item.path === '/').children;

        // Junvary：不在使用这个menus
        // this.menus = this.permissionMenuList
        this.$store.dispatch('ShowSidebar', true)
        this.fillMenus()

        //--update-begin----author:liusq---date:20210223------for:关于测边菜单遮挡内容问题详细说明 #2255
        this.collapsed = !this.sidebarOpened;
        //--update-begin----author:liusq---date:20210223------for:关于测边菜单遮挡内容问题详细说明 #2255

        // 根据后台配置菜单，重新排序加载路由信息
        //console.log('----加载菜单逻辑----')
        //console.log(this.mainRouters)
        //console.log(this.permissionMenuList)
        //console.log('----navTheme------'+this.navTheme)
        //--update-end----author:scott---date:20190320------for:根据后台菜单配置，判断是否路由菜单字段，动态选择是否生成路由（为了支持参数URL菜单）------
    },
    methods: {
        // Junvary：填充侧边栏内容的方法
        fillMenus() {
            // console.log(this.permissionMenuList[this.menuIndex])
            // 这里通过permission里面对应index的path去判断
            const ifShow =
                this.menuIndex === 0 ||
                this.noSidebarMenuList.indexOf(this.permissionMenuList[this.menuIndex].path) !== -1
            if (ifShow) {
                // 首页不显示侧边栏
                this.$store.dispatch('ShowSidebar', false)
                this.menus = []
            } else {
                // 其他页面显示侧边栏
                this.$store.dispatch('ShowSidebar', true)
                this.menus = this.permissionMenuList[this.menuIndex].children
            }
        },
        ...mapActions(['setSidebar']),
        toggle() {
            this.collapsed = !this.collapsed
            this.setSidebar(!this.collapsed)
            triggerWindowResizeEvent()
        },
        menuSelect() {
            if (!this.isDesktop()) {
                this.collapsed = false
            }
        },
        //update-begin-author:taoyan date:20190430 for:动态路由title显示配置的菜单title而不是其对应路由的title
        myMenuSelect(value) {
            //此处触发动态路由被点击事件
            this.findMenuBykey(this.menus, value.key)
            this.$emit("dynamicRouterShow", value.key, this.activeMenu.meta.title)
        },
        findMenuBykey(menus, key) {
            for (let i of menus) {
                if (i.path == key) {
                    this.activeMenu = { ...i }
                } else if (i.children && i.children.length > 0) {
                    this.findMenuBykey(i.children, key)
                }
            }
        },
        //update-end-author:taoyan date:20190430 for:动态路由title显示配置的菜单title而不是其对应路由的title

        // update-begin-author:sunjianlei date:20210409 for: 修复动态功能测试菜单、带参数菜单标题错误、展开错误的问题
        handleUpdateMenuTitle(value) {
            this.findMenuBykey(this.menus, value.path)
            this.activeMenu.meta.title = value.meta.title
            this.$emit('dynamicRouterShow', value.path, this.activeMenu.meta.title)
        },
        // update-end-author:sunjianlei date:20210409 for: 修复动态功能测试菜单、带参数菜单标题错误、展开错误的问题

    }
}

</script>

<style lang="less">
body {
    // 打开滚动条固定显示
    // 注释原因：issues/I5VK11
    //overflow-y: scroll;

    &.colorWeak {
        filter: invert(80%);
    }
}

.layout {
    min-height: 100vh !important;
    overflow-x: hidden;

    &.mobile {

        .ant-layout-content {

            .content {
                margin: 24px 0 0;
            }
        }

        /**
       * ant-table-wrapper
       * 覆盖的表格手机模式样式，如果想修改在手机上表格最低宽度，可以在这里改动
       */
        .ant-table-wrapper {
            .ant-table-content {
                overflow-y: auto;
            }

            .ant-table-body {
                // update-begin---author:sunjianlei Date:20220104 for： 【JTC-480】移动端不支持左右拖动，需要注释掉此段代码 ------------
                //min-width: 800px;
                // update-end---author:sunjianlei Date:20220104 for： 【JTC-480】移动端不支持左右拖动，需要注释掉此段代码 ------------
            }
        }

        .sidemenu {
            .ant-header-fixedHeader {

                &.ant-header-side-opened,
                &.ant-header-side-closed {
                    width: 100%
                }
            }
        }

        .topmenu {

            /* 必须为 topmenu  才能启用流式布局 */
            &.content-width-Fluid {
                .header-index-wide {
                    margin-left: 0;
                }
            }
        }

        .header,
        .top-nav-header-index {
            .user-wrapper .action {
                padding: 0 12px;
            }
        }
    }

    &.ant-layout-has-sider {
        flex-direction: row;
    }

    .trigger {
        font-size: 22px;
        line-height: 42px;
        padding: 0 18px;
        cursor: pointer;
        transition: color 300ms, background 300ms;

        &:hover {
            background: rgba(255, 255, 255, 0.3);
        }
    }

    .topmenu {
        .ant-header-fixedHeader {
            position: fixed;
            top: 0;
            right: 0;
            z-index: 9;
            width: 100%;
            transition: width .2s;

            &.ant-header-side-opened {
                width: 100%;
            }

            &.ant-header-side-closed {
                width: 100%;
            }
        }

        /* 必须为 topmenu  才能启用流式布局 */
        &.content-width-Fluid {
            .header-index-wide {
                max-width: unset;
                margin-left: 24px;
            }

            .page-header-index-wide {
                max-width: unset;
            }
        }

    }

    .sidemenu {
        .ant-header-fixedHeader {
            position: fixed;
            top: 0;
            right: 0;
            z-index: 9;
            width: 100%;
            transition: width .2s;

            &.ant-header-side-opened {
                width: calc(100% - 200px)
            }

            &.ant-header-side-closed {
                width: calc(100% - 80px)
            }
        }
    }

    .header {
        height: 64px;
        padding: 0 12px 0 0;
        background: #fff;
        box-shadow: 0 1px 4px rgba(0, 21, 41, .08);
        position: relative;
    }

    .header,
    .top-nav-header-index {

        .user-wrapper {
            float: right;
            height: 100%;

            .action {
                cursor: pointer;
                padding: 0 14px;
                display: inline-block;
                transition: all .3s;

                height: 70%;
                line-height: 46px;

                &.action-full {
                    height: 100%;
                }

                &:hover {
                    background: rgba(255, 255, 255, 0.3);
                }

                .avatar {
                    margin: 20px 10px 20px 0;
                    color: #1890ff;
                    background: hsla(0, 0%, 100%, .85);
                    vertical-align: middle;
                }

                .icon {
                    font-size: 16px;
                    padding: 4px;
                }

                .anticon {
                    color: inherit;
                }
            }
        }

        &.dark {
            .user-wrapper {

                .action {
                    color: black;

                    &:hover {
                        background: rgba(0, 0, 0, 0.05);
                    }

                    .anticon {
                        color: inherit;
                    }
                }
            }
        }
    }

    &.mobile {
        .top-nav-header-index {

            .header-index-wide {

                .header-index-left {

                    .trigger {
                        color: rgba(255, 255, 255, 0.85);
                        padding: 0 12px;
                    }

                    .logo.top-nav-header {
                        text-align: center;
                        width: 56px;
                        line-height: 58px;
                    }
                }
            }

            .user-wrapper .action .avatar {
                margin: 20px 0;
            }

            &.light {

                .header-index-wide {

                    .header-index-left {
                        .trigger {
                            color: rgba(0, 0, 0, 0.65);
                        }
                    }
                }

                //
            }
        }
    }

    &.tablet {

        // overflow: hidden; text-overflow:ellipsis; white-space: nowrap;
        .top-nav-header-index {

            .header-index-wide {

                .header-index-left {
                    .logo>a {
                        overflow: hidden;
                        text-overflow: ellipsis;
                        white-space: nowrap;
                    }
                }
            }
        }

    }

    .top-nav-header-index {
        box-shadow: 0 1px 4px rgba(0, 21, 41, .08);
        position: relative;
        transition: background .3s, width .2s;

        .header-index-wide {
            width: 100%;
            margin: auto;
            padding: 0 20px 0 0;
            display: flex;
            height: 59px;

            .ant-menu.ant-menu-horizontal {
                border: none;
                height: 64px;
                line-height: 64px;
            }

            .header-index-left {
                flex: 1 1;
                display: flex;

                .logo.top-nav-header {
                    width: 165px;
                    height: 64px;
                    position: relative;
                    line-height: 64px;
                    transition: all .3s;
                    overflow: hidden;

                    img {
                        display: inline-block;
                        vertical-align: middle;
                        height: 32px;
                    }

                    h1 {
                        color: #fff;
                        display: inline-block;
                        vertical-align: top;
                        font-size: 16px;
                        margin: 0 0 0 12px;
                        font-weight: 400;
                    }
                }
            }

            .header-index-right {
                float: right;
                height: 59px;
                overflow: hidden;

                .action:hover {
                    background-color: rgba(0, 0, 0, 0.05);
                }
            }
        }

        &.light {
            background-color: #fff;

            .header-index-wide {
                .header-index-left {
                    .logo {
                        h1 {
                            color: #002140;
                        }
                    }
                }
            }
        }

        &.dark {

            .user-wrapper {

                .action {
                    color: white;

                    &:hover {
                        background: rgba(255, 255, 255, 0.3);
                    }
                }
            }

            .header-index-wide .header-index-left .trigger:hover {
                background: rgba(255, 255, 255, 0.3);
            }
        }

    }

    // 内容区
    .layout-content {
        margin: 24px 24px 0px;
        height: 64px;
        padding: 0 12px 0 0;
    }

}

.topmenu {
    .page-header-index-wide {
        margin: 0 auto;
        width: 100%;
    }
}

// drawer-sider 自定义
.ant-drawer.drawer-sider {
    .sider {
        box-shadow: none;
    }

    &.dark {
        .ant-drawer-content {
            background-color: rgb(0, 21, 41);
        }
    }

    &.light {
        box-shadow: none;

        .ant-drawer-content {
            background-color: #fff;
        }
    }

    .ant-drawer-body {
        padding: 0
    }
}

// 菜单样式
.sider {
    box-shadow: 2px 116px 6px 0 rgba(0, 21, 41, .35);
    position: relative;
    z-index: 10;

    &.ant-fixed-sidemenu {
        position: fixed;
        height: 100%;
    }

    .logo {
        height: 64px;
        position: relative;
        line-height: 64px;
        padding-left: 24px;
        -webkit-transition: all .3s;
        transition: all .3s;
        background: #002140;
        overflow: hidden;

        img,
        h1 {
            display: inline-block;
            vertical-align: middle;
        }

        img {
            height: 32px;
        }

        h1 {
            color: #fff;
            font-size: 18px;
            margin: 0 0 0 8px;
            font-family: "Chinese Quote", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Helvetica Neue", Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
            font-weight: 600;
        }
    }

    &.light {
        background-color: #fff;
        box-shadow: 2px 116px 8px 0 rgba(29, 35, 41, 0.05);

        .logo {
            background: #fff;
            box-shadow: 1px 1px 0 0 #e8e8e8;

            h1 {
                color: unset;
            }
        }

        .ant-menu-light {
            border-right-color: transparent;
        }
    }

}

// 外置的样式控制
.user-dropdown-menu-wrapper.ant-dropdown-menu {
    padding: 4px 0;

    .ant-dropdown-menu-item {
        width: 160px;
    }

    .ant-dropdown-menu-item>.anticon:first-child,
    .ant-dropdown-menu-item>a>.anticon:first-child,
    .ant-dropdown-menu-submenu-title>.anticon:first-child .ant-dropdown-menu-submenu-title>a>.anticon:first-child {
        min-width: 12px;
        margin-right: 8px;
    }

}

// 数据列表 样式
.table-alert {
    margin-bottom: 16px;
}

.table-page-search-wrapper {

    .ant-form-inline {

        .ant-form-item {
            display: flex;
            margin-bottom: 24px;
            margin-right: 0;

            .ant-form-item-control-wrapper {
                flex: 1 1;
                display: inline-block;
                vertical-align: middle;
            }

            >.ant-form-item-label {
                line-height: 32px;
                padding-right: 8px;
                width: auto;
            }

            .ant-form-item-control {
                height: 32px;
                line-height: 32px;
            }
        }
    }

    .table-page-search-submitButtons {
        display: block;
        margin-bottom: 24px;
        white-space: nowrap;
    }

}

.content {

    .table-operator {
        margin-bottom: 18px;

        button {
            margin-right: 8px;
        }
    }
}
</style>
